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INTELLIGENCE SERVER SYSTEM 

FIELD OF THE INVENTION 

The invention relates to the field of data processing and analytics and, more particularly, 
5 to a scalable and customizable business intelligence platform. 

BACKGROUND OF THE INVENTION 
y The ability to act quickly and decisively in today's increasingly competitive marketplace 

ili. is critical to the success of any organization. The volume of data that is available to 
|D organizations is rapidly increasing and frequently overwhelming. The availability of large 
1U volumes of data presents various challenges. One challenge is to avoid inundating a user with 
y unnecessary information. Another challenge is to ensure all relevant information is available in a 
m timely manner. 

=1 One known approach to addressing these and other challenges is known as data 

15 warehousing. Data warehouses, relational databases, and data marts are becoming important 
elements of many information delivery systems because they provide a central location where a 
reconciled version of data extracted from a wide variety of operational systems may be stored. 
As used herein, a data warehouse should be understood to be an informational database that 
stores shareable data from one or more operational databases of record, such as one or more 
20 transaction-based database systems. A data warehouse typically allows a user to tap into an 

organization's vast store of operational data to track and respond to business trends that facilitate 
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forecasting and planning efforts. A data mart may be considered to be a type of data warehouse 

that focuses on a particular business segment. 

Decision support ("DSS"), business intelligence and reporting systems have been 

developed to efficiently retrieve selected information from data warehouses. One type of 
5 reporting system is known as an on-line analytical processing system ("OLAP"). In general, 

OLAP reporting systems analyze the data from a number of different perspectives and support 

complex analyses against large input data sets, 
y There are at least three different types of OLAP architectures: Relational On-Line 

JJ Analytical Processing (ROLAP), Multidimensional On-Line Analytical Processing (MOLAP), 
B and Hybrid Analytical Processing (HOLAP). ROLAP systems use a dynamic server connected to 
llj a relational database system. MOLAP systems utilize a proprietary multidimensional database 
G (MDDB) to provide OLAP analyses. The main premise of this architecture is that data must be 
I ^ stored multidimensional^ to be viewed multidimensional^. HOLAP systems are a hybrid of the 
iu other two. 

15 ROLAP is a three-tier, client/server architecture comprising a presentation tier, an 

application logic tier, and a relational database tier. The relational database tier stores data and 
connects to the application logic tier. The application logic tier comprises a ROLAP engine that 
executes multidimensional reports from multiple end users. The ROLAP engine integrates with 
a variety of presentation layers, through which users perform OLAP analyses. The presentation 

20 layers enable users to provide requests to the ROLAP engine. The premise of ROLAP is that 
OLAP capabilities are best provided directly against a relational database (e.g., the data 
warehouse). 
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In a ROLAP system, data from transaction-processing systems is loaded into a defined 
data model in the data warehouse. Database routines are run to aggregate the data, if required by 
the data model Indices are then created to optimize query access times. End users submit 
multidimensional analyses to the ROLAP engine, which then dynamically transforms the 
5 requests into standard query language (SQL) execution plans. The SQL is submitted to the 
relational database for processing, the relational query results are cross-tabulated, and a 
multidimensional result set is returned to the end user. ROLAP is a fully dynamic architecture 
l i capable of utilizing pre-calculated results when they are available, or dynamically generating 
] 5 results from atomic information when necessary. 

|D The ROLAP architecture directly accesses data from data warehouses and, therefore, 

ill supports optimization techniques to meet batch window requirements and to provide fast 
h i response times. These optimization techniques typically include application level table 
% partitioning, aggregate inferencing, denormalization support, and multiple fact table joins. 
\1 MOLAP is a two-tier, client/server architecture. In this architecture, the MDDB serves as 

15 both the database layer and the application logic layer. In the database layer, the MDDB system 
is responsible for all data storage, access, and retrieval processes. In the application logic layer, 
the MDDB is responsible for the execution of all OLAP requests. The presentation layer 
integrates with the application logic layer and provides an interface through which the end users 
view and request OLAP analyses. The client/server architecture allows multiple users to access 
20 the multidimensional database. 

Information from a variety of transaction-processing systems is loaded into the MDDB 
system through a series of batch routines. Once this atomic data has been loaded into the 
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MDDB, the general approach is to perform a series of batch calculations to aggregate along the 
orthogonal dimensions and fill the MDDB array structures. For example, revenue figures for all 
of the stores in a state would be added together to fill the state level cells in the database. After 
the array structure in the database has been filled, indices are created and hashing algorithms are 
5 used to improve query access times. Once this compilation process has been completed, the 
MDDB is ready for use. Users request OLAP reports through the presentation layer, and the 
application logic layer of the MDDB retrieves the stored data. 
1 2 The MOLAP architecture is a compilation-intensive architecture. It principally reads the 

jJ5 pre-compiled data, and has limited capabilities to dynamically create aggregations or to calculate 
jpD business metrics that have not been pre-calculated and stored. 

1*4 The hybrid OLAP (HOLAP) solution is a mix of MOLAP and relational architectures that 

! support inquiries against summary and transaction data in an integrated fashion. The HOLAP 
J ^ approach enables a user to perform multidimensional analysis on data in the MDDB. However, 
hi if the user reaches the bottom of the multidimensional hierarchy and requires more detailed data, 
15 the HOLAP engine generates an SQL to retrieve the detailed data from a source relational 
database management system (RDBMS) and returns it to the end user. HOLAP implementations 
rely on simple SQL statements to pull large quantities of data into the mid-tier, multidimensional 
engine for processing. This constrains the range of inquiry and returns large, unrefined result sets 
that can overwhelm networks with limited bandwidth. 
20 As described above, each of these types of OLAP systems are typically client-server 

systems. The OLAP engine resides on the server-side and a module is typically provided at a 
client-side to enable users to input queries and report requests to the OLAP engine. In some 

-4- 



PATENT 

Attorney Docket No. 53470.003022 

systems, such queries and report requests are directed to a single designated server upon which 
the OLAP engine resides. Thus, if this single designated server fails, all previously input queries 
and report requests are typically lost and each user typically has to input new queries and report 
requests to another single designated server upon which another OLAP engine resides. This can 
5 obviously be time consuming and costly. 

In other systems, such queries and report requests may be directed to one of several 
servers, each of which contains an OLAP engine. Typically, a user is assigned to one of these 
'5 servers based upon a simple sequential scheme (e.g., a round-robin scheme). However, as with 
JJf the single designated server described above, if any one of these several servers fails, all 
B previously input queries and report requests are typically lost and each user typically has to input 
m new queries and report requests to another one of several servers. Even if none of these several 
!2 servers fails, there still may be loading problems associated with the servers. That is, some 
J I queries and report requests may be significantly more intensive and time consuming than others, 
n and these more intensive and time consuming queries and report requests may be assigned to the 
15 same server. Thus, some servers may be overloaded, while other servers may be underloaded. 
This can obviously be very inefficient. 

Another drawback of existing reporting systems is that they tend to be designed for one 
specific operating system or platform and one specific client interface. Many reporting systems 
are also based upon proprietary formats. For example, an existing reporting system may be 
20 designed for the Microsoft Windows operating system environment and cannot be used for web- 
based reporting applications and vice versa. Today, however, where many organizations are 
large enterprises of different businesses and include many different types of computers, databases 
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and reporting requirements, reporting systems based on closed, proprietary standards lack the 
flexibility needed for such robust business environments. 

Another drawback of existing systems is that many are designed for use with only a single 
type of database format. However, there are many commonly-used database formats such as 
5 Microsoft Access, SQL, DB2 and many others. A flexible platform based on open standards is 
needed to support analytical and reporting applications across multiple types of database formats. 

These and other drawbacks exist with respect to current reporting systems. 



J;J{ BRIEF SUMMARY OF THE INVENTION 

J[) It is therefore an object of the present invention to provide a reporting system having a 

m component based architecture wherein such components are invoked on an as-needed basis in 
1 5 order to avoid overloading servers. 

It is an additional object of the invention to provide a reporting system which serves 
i T business intelligence and reporting applications from any operating system environment. 
15 It is a further object of the invention to provide a reporting system that facilitates 

interaction with all standard database formats. 

Additional objects and advantages of the invention will be set forth in part in the 
description which follows, or may be learned by practice of the invention. The objects and 
advantages of the invention may be realized and attained by means of the instrumentalities and 
20 combinations particularly pointed out in the appended claims. 

To achieve the objects and in accordance with the purpose of the invention, as embodied 
and broadly described herein, this invention, in one aspect, includes a reporting system 
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comprising a a report initiating module that generates a request for a report (e.g., a user engine, 
calling application or other report request system, including systems connected over various 
networks to the intelligence server); one or more data storage devices for holding the data used 
for generating the report; an intelligence server, in communication with the user engine, for 
5 receiving the generated request from the user engine, and for routing the request for processing, 
the intelligence server including an object server for controlling and managing all application 
objects independent of an interface or a user; an administrative facility for managing activity of 
O the intelligence server; a query engine for mediating the generated request received from the user 
!i engine to format and process the request, submitting the request against the data stored in the one 
|f) or more data storage devices, extracting the data from the data storage devices and returning one 
III or more result sets from the submitted request; and an analytical engine for receiving the result 
O sets, performing further processing of the result sets by running a plurality of statistical analyses 

of the data included in the result sets to generate a report for presentation to a user. 
|T In another aspect, the invention includes a method for generating a report comprising the 

1 5 steps of receiving a request for a report from a user; transmitting the received request to a query 
engine; identifying one or more data storage devices to receive the request; transmitting the 
request to the identified one or more data storage devices; extracting data from the one or more 
data storage devices responsive to the transmitted request to form one or more result sets; 
transmitting the one or more result sets to an analytical engine; and generating a report from the 
20 one or more result sets. 

In yet another aspect, the invention includes an intelligence server for a reporting system, 
wherein the reporting system includes a report initiating module that generates a request for a 
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report, the intelligence server comprising a server layer for receiving the generated request and 
for coordinating a flow and a processing order of the received request in accordance with a 
predetermined prioritization scheme; an application logic layer including a plurality of business 
intelligence rules used for generating the report; an interface layer between the server layer and 
the application logic layer; an analytical layer, in communication with the user engine and the 
server layer, for receiving the request to be processed from the server layer, transmitting the 
processed request to one or more data storage devices, and for extracting data from the one or 
more data storage devices responsive to the transmitted request; and an interface layer between 
the server layer and the analytical layer; wherein the extracted data is processed by the 
application logic layer to generate the report and the processing is independent of a user 
interface. 

The accompanying drawings, which are incorporated in and constitute a part of this 
specification, illustrate the embodiments of the invention and, together with the description, 
serve to explain the principles of the invention. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram illustrating an architecture for a reporting system according to 
an embodiment of the invention. 

Fig. 2 is a flowchart illustrating steps performed by a process utilizing a query engine 
according to an embodiment of the invention. 

Fig. 3 illustrates a block diagram of an intelligent server according to an embodiment of 
the invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

Reference will now be made in detail to the present preferred embodiments of the 
invention, examples of which are illustrated in the accompanying drawings in which like 
5 reference characters refer to corresponding elements. 

Fig. 1 is a block diagram illustrating a reporting system 100 by which a variety of data 
resources may be accessed for business analytic, report generation and other intelligence 
Q purposes according to an embodiment of the invention. According to a preferred embodiment, 

the reporting system 100 may comprise a business intelligence, Online Analytical Processing 
|| (OLAP) decision support system (DSS) or other reporting system. In particular, Fig. 1 may 
ID comprise a portion of the MicroStrategy 7 or 7. 1 platform which provides a preferred system in 
^ which the present invention may be implemented. 

IS In general, through using the reporting system 100 of the invention, analysts, managers 

'\2 and other users may query or interrogate a plurality of databases or database arrays to extract 
15 demographic, sales, and/or financial data and information and other patterns from records stored 
in such databases or database arrays to identify strategic trends. Those strategic trends may not 
be discernable without processing the queries and treating the results of the data extraction 
according to the techniques performed by the systems and methods of the invention. This is in 
part because the size and complexity of some data portfolios stored in such databases or database 
20 arrays may mask those trends. 

In addition, the reporting system 100 may enable the creation of reports or the provision 
of services that are processed according to a predetermined schedule. The user may then 
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subscribe to the services, provide personalization criteria and have the reports automatically 
delivered to the user, as described in U.S. Patent No. 6,1 54,766 to Yost et al (the "'766 Patent"), 
which is commonly assigned and hereby incorporated by reference. 

As illustrated in Fig. 1, a business, a government or another user may access the resources 
5 of the reporting system 100 using a user engine 102. The user engine 102 may include a query 
input module 1 16 to accept a plurality of searches, queries or other requests, via a query box on a 
graphical user interface (GUI) or another similar interface. The user engine 102 may 

^ communicate with an analytical engine 104. The analytical engine 104 may include a set of 

extensible modules to run a plurality of statistical analyses, to apply filtering criteria, to perform a 

5 S neural net technique or another technique to condition and treat data extracted from data 

VU resources hosted in the reporting system 100, according to a query received from the user engine 

S 102. 

] 2 The analytical engine 1 04 may communicate with a query engine 1 06, which in turn 

\2 interfaces to one or more data storage devices 108a, 108b . . . 108n (where n is an arbitrary 
15 number). The data storage devices 108a, 108b .. . 108n may include or interface to a relational 
database or another structured database stored on a hard disk, an optical disk, a solid state device 
or another similar storage media. When implemented as databases, the data storage devices 
108a, 108b .. . 108n may include or interface to, for example, an Oracle™ relational database 
such as sold commercially by Oracle Corporation, an Informix™ database, a Database 2 (DB2) 
20 database, a Sybase™ database, or another data storage device or query format, platform or 
resource such as an OLAP format, a Standard Query Language (SQL) format, a storage area 
network (SAN), or a Microsoft Access™ database. It should be understood that while data 
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storage devices 108a, 108b ... 1 08n are illustrated as a plurality of data storage devices, in some 
embodiments the data storage devices may be contained within a single database or another 
single resource. 

Any of the user engine 102, the analytical engine 104 and the query engine 106 or other 
5 resources of the reporting system 1 00 may include or interface to or be supported by computing 
resources, such as one or more associated servers. When a server is employed for support, the 
server may include, for instance, a workstation running a Microsoft Windows NT operating 
O system, a Windows™ 2000 operating system, a Unix operating system, a Linux operating 
J 2 system, a Xenix operating system, an IBM AIX operating system, a Hewlett-Packard TJX 
lO operating system, a Novell Netware™ operating system, a Sun Microsystems Solaris™ operating 
m system, an OS/2™ operating system, a BeOS™ operating system, a Macintosh operating system, 
O an Apache platform, an OpenStep™ operating system, or another similar operating system or 
I'i, platform. According to one embodiment of the present invention, the analytical engine 104 and 
i2 the query engine 106 may comprise elements of an intelligence server 103. 
1 5 The data storage devices 1 08a, 1 08b ... 1 08n may be supported by a server or another 

resource and may, in some embodiments, include redundancy, such as a redundant array of 
independent disks (RAID), for data protection. The storage capacity of any one or more of the 
data storage devices 108a, 108b .. . 108n may be of various sizes, from relatively small data sets 
to very large database (VLDB)-scale data sets, such as warehouses holding terabytes of data or 
20 more. The fields and types of data stored within the data storage devices 1 08a, 1 08b ... 1 08n 
may also be diverse, and may include, for instance, financial, personal, news, marketing, 
technical, addressing, governmental, military, medical or other categories of data or information. 
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The query engine 106 may mediate one or more queries or information requests from 
those received from the user at the user engine 102 to parse, filter, format and otherwise process 
such queries to be submitted against the data contained in the data storage devices 108a, 108b . . . 
108n. Thus, a user at the user engine 102 may submit a query requesting information in SQL 
format, or have the query translated to SQL format. The submitted query is then transmitted via 
the analytical engine 104 to the query engine 106. The query engine 106 may determine, for 
instance, whether the transmitted query may be processed by one or more resources of the data 
storage devices 108a, 108b ... 108n in its original format. If so, the query engine 106 may 
directly transmit the query to one or more of the resources of the data storage devices 108a, 108b 
... 108n for processing. 

If the transmitted query cannot be processed in its original format, the query engine 106 
may perform a translation of the query from an original syntax to a syntax compatible with one or 
more of the data storage devices 108a, 108b ... 108n by invoking a syntax module 1 18 to 
conform the syntax of the query to standard SQL, DB2, Informix™, Sybase™ formats or to other 
data structures, syntax or logic. The query engine 106 may likewise parse the transmitted query 
to determine whether it includes any invalid formatting or to trap other errors included in the 
transmitted query, such as a request for sales data for a future year or other similar types of 
errors. Upon detecting an invalid or an unsupported query, the query engine 106 may pass an 
error message back to the user engine 102 to await further user input. 

When a valid query such as a search request is received and conformed to a proper 
format, the query engine 106 may pass the query to one or more of the data storage devices 108a, 
1 08n . . . 1 08n for processing. In some embodiments, the query may be processed for one or more 
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hits against one or more databases in the data storage devices 108a, 108b .. . 108n. For example, 
a manager of a restaurant chain, a retail vendor or another similar user may submit a query to 
view gross sales made by the restaurant chain or retail vendor in the State of New York for the 
year 1999. The data storage devices 108a, 108b . . . 108n may be searched for one or more fields 
corresponding to the query to generate a set of results 114. 

Although illustrated in connection with each data storage device 108 in Fig. 1, the results 
1 14 may be generated from querying any one or more of the databases of the data storage devices 
108a, 108b . 108n, depending on which of the data resources produce hits from processing the 
search query. In some embodiments of the reporting system 100 of the invention, the results 1 14 
may be maintained on one or more of the data storage devices 108a, 108b ... 108n to permit one 
or more refinements, iterated queries, joinders or other operations to be performed on the data 
included in the results 1 14 before passing the information included in the results 1 14 back to the 
analytical engine 104 and other elements of the reporting system 100. 

When any such refinements or other operations are concluded, the results 1 14 may be 
transmitted to the analytical engine 104 via the query engine 106. The analytical engine 104 may 
then perform statistical, logical or other operations on the results 1 14 for presentation to the user. 
For instance, the user may submit a query asking which of its retail stores in the State of New 
York reached $1M in sales at the earliest time in the year 1999. Or, the user may submit a query 
asking for an average, a mean and a standard deviation of an account balance on a portfolio of 
credit or other accounts. 

The analytical engine 104 may process such queries to generate a quantitative report 110, 
which may include a table or other output indicating the results 1 14 extracted from the data 
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f 

storage devices 108a 5 108b . . . 108n. The report 1 10 may be presented to the user via the user 
engine 102, and, in some embodiments, may be temporarily or permanently stored on the user 
engine 102, a client machine or elsewhere, or printed or otherwise output. In some embodiments 
of the reporting system 100 of the invention, the report 1 10 or other output may be transmitted to 
5 a transmission facility 1 12, for transmission to a set of personnel via an email, an instant 

message, a text-to-voice message, a video or via another channel or medium. The transmission 
facility 1 12 may include or interface to, for example, a personalized broadcast platform or service 
O such as the Narrowcaster™ platform or Telecaster™ service sold by MicroStrategy Incorporated 
jjf or another similar communications channel or medium. Similarly, in some embodiments of the 
$0 invention, more than one user engine 102 or other client resource may permit multiple users to 
! !J view the report 1 1 0, such as, for instance, via a corporate intranet or over the Internet using a 
O Web browser. Various authorization and access protocols may be employed for security 
: s z purposes to vary the access permitted users to such report 1 10 in such embodiments. 
I ]? Additionally, as described in the '766 Patent, an administrative level user may create a 

15 report as part of a service. Subscribers/users of the service may then receive access to reports 
through various types of data delivery devices including telephones, pagers, computers, PDAs, 
WAP protocol devices, email, facsimile, and many others. In addition, a subscriber/user may 
specify trigger conditions so that the subscriber/user receives a report only when a trigger 
condition has been satisfied, as described in detail in the '766 Patent. The reporting system 100 
20 of Fig. 1 may have many other uses, as described in detail with respect to the MicroStrategy 7 
and 7.1 platforms, the details of which will be appreciated by one of ordinary skill in the 
reporting and decision support system art. 
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The steps performed in a method 200 for processing data according to the invention are 
illustrated in the flowchart of Fig. 2. In step 202, the method 200 begins. In step 204, the user 
may supply input, such as a query or a request for information, via the user engine 102. In step 
206, the user input query may be preliminarily processed, for instance, to determine whether it 

5 includes valid fields and for other formatting and error-flagging issues. In step 208, any error 
conditions may be trapped and an error message presented to the user, for correction of the error 
conditions. In step 210, if a query is in a valid format, the query may then be transmitted to the 

»f analytical engine 104. 

K In step 212, the analytical engine 104 may resolve the query request directly or determine 

|p that the query requires further processing by the query engine 106. In step 214, the query engine 
II 1 06 may further filter, format and otherwise process the input query to ensure that the query is in 
a syntax compatible with the syntax of the data storage devices 1 08a, 1 08b ... 1 08n. In step 216, 
ij one or more appropriate databases or other resources within the data storage devices 108a, 108b 
2 ... 1 08n may be identified to be accessed for the given query. 

15 In step 218, the query may be transmitted to the data storage devices 108a, 108b ... 108n 

and the query may be processed for hits or other results 1 14 against the content of the data 
storage devices 1 08a, 1 08b ... 1 08n. In step 220, the results 1 1 4 of the query may be refined, and 
intermediate or other corresponding results 114 may be stored in the data storage devices 108a, 
108b ... 108n. In step 222, the final results 114 of the processing of the query against the data 

20 storage devices 108a, 108b . . . 108n may be transmitted to the analytical engine 104 via the query 
engine 106. In step 224, a plurality of analytical measures, filters, thresholds, statistical or other 
treatments may be run on the results 1 1 4. In step 226, a report 1 1 0 may be generated. The 
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report 1 10, or other output of the analytic or other processing steps, may be presented to the user 
via the user engine 102. In step 228, the method 200 ends. 

In a particular embodiment of the invention illustrated in Fig. 3, some or all of the 
functions of the reporting system 100 can be centralized and included as components of an 
5 intelligence server 300 (or the intelligence server 103 of Fig. 1). The intelligence server 300 
hosts the components required for analytical execution of requests, report execution, element 
browsing and DSS application logic and object operations. The intelligence server 300 may also 
G include additional plug-in components 120 which can further extend the functional capabilities of 
j J the intelligence server 300. For example, the intelligence server 300 may include a cross 
Jp tabulation module 306, an XML generation module 320, a metadata server 3 1 8, a document 
I II server 3 1 6, the transmission facility 1 1 2 and a plurality of other applications 3 1 2 as needed to 
Q realize a robust reporting system 1 00 capable of responding to the needs of a vast array of users 
LJ: across the entire enterprise of an organization independent of the type of user interface employed, 
jl The various functional modules may communicate, interact with and interface to one another 
1 5 through an intelligence pipeline 310. 

The intelligence server 300 has a component-based architecture referred to as "intelligent 
portal architecture" wherein the functions of the reporting system 100 are all component-level 
services which can be invoked on an as-needed basis based upon usage requirements to ensure 
efficient operation of the reporting system 100. The processing logic of the intelligence server 
20 300 provides for the handling of requests by queueing and prioritization and is driven by a 
logistic module that directs workflow to proper processing components as invoked. For 
example, the intelligence server 300 may use a dependency map that defines an input and an 
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output of each processing step to generate a road map for each request. Based on the generated 
roadmap, the intelligence server 300 routes the request to a specific component or components in 
a proper order until the request is processed. Requests that are received by the intelligence server 
300 are handled by a dispatcher component within the intelligence pipeline 310. The dispatcher 
component forwards each request to a server appropriate to the request. The intelligence server 
300 may also include a component to enforce system security (not shown). 

Additionally, because of the plug-in nature of the components, the intelligence server 300 
can be customized to suit a particular business enterprise's needs. For example, for 
computationally intensive applications, the intelligence server 300 may increase the resources 
dedicated to the analytical engine 104. Or, alternatively, the intelligence server 300 can include 
multiple analytical engines 104 having discrete resources allocated to each analytical engine 104. 
In this manner, a scalable business intelligence and reporting system 100 can be achieved thereby 
realizing the ability to respond to requests of many diverse users across an organization's 
enterprise or in different organizations. 

The intelligence server 300 also acts to coordinate and synchronize the flow of requests 
within the various components resident in the intelligence server 300 by use of queueing, 
prioritization and governing mechanisms. The dispatcher component looks for an underutilized 
server that can efficiently process the request. When load on the intelligence server 300 exceeds 
a predetermined threshold load, more intelligence servers 300 can be added to the reporting 
system 100. If a server experiences a failure, a request can be re-routed to another server. Thus, 
loads are balanced across components preventing the reporting system 100 from becoming 
overloaded and failing. 

-17- 



PATENT 

Attorney Docket No. 53470.003022 

Intelligent portal architecture also differs from traditional client-server architecture 
because it is based upon open web-based standards such as Java, HTML and XML rather than 
proprietary formats. Thus, processing of requests by the intelligence server 300 can be conducted 
independent of the type of user interface employed at a user engine 102. Open web-based 
5 standards also help to provide a secure, high performance, low cost reporting system 100 capable 
of rapid deployment of quality business reports which may be easily distributed to users, such as 
via a web site or via email and also enable reports to be more easily customized to a user's needs. 
O The intelligence server 300 also provides centralized database access and management for 

| J its components. To boost performance, the intelligence server 300 may further utilize database 
|0 connection pooling, monitoring and governing to control the overall processing load to each 
m server and better utilize database servers. 

O The intelligence server 300 is designed to communicate with users of all types, with user 

\z interfaces of all types, with Web servers, and with other application servers (such as SAP, People 
\ ]f Soft and others) to take/send user requests and to exchange data in a variety of formats. For 
15 example, with the emergence of XML, the intelligence server 300 may provide a more open 
communication protocol by talking in this new open standard language, i.e., a user can send a 
request to the intelligence server 300 in an XML string, and the intelligence server 300 will send 
back its result in XML as well. 

As shown in Fig. 3, the intelligence server 300 can be thought of as consisting of four 
20 functional layers. The four layers of the intelligence server 300 include (at the highest level) a 
server layer which, as described above, functions to handle requests from multiple interface 
agents including user interfaces (UIs) and application programming interfaces (APIs). The server 
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layer also functions to coordinate the handling and flow of requests within the various 
components resident in the intelligence server 300 including queueing, prioritization, and 
governing mechanisms. 

An analytical layer comprising the analytical engine 104 and the query engine 106, for 
5 example, provides all services for decision support. As described above, the analytical engine 
104 processes result sets 1 14 to generate a quantitative report 110 which may be presented to a 
user at the user engine 102 or transmitted to the transmission facility 1 12 for transmission to 
O users. The query engine 106 communicates with one or more data storage devices 108 so as to 
jj: obtain requested data, as also described above. 

tb The intelligence server 300 further includes an application logic layer which includes all 

l!j of the objects necessary for supporting a business intelligence application including, for example, 
13 reports and projects. In other words, all of the application logic and business intelligence rules 
\z needed for the reporting system 100 reside in a single centralized location, i.e., in the intelligence 
i2 server 300. Additionally, a set of application programming interfaces (APIs) serves as an 
1 5 interface between the server layer and the application logic layer to coordinate user requests, 
administrative requests, design requests and application requests. 

The intelligence server 300 may further include a statistical data module 322 that 
monitors and captures data relating to the usage patterns of the intelligence server 300 in a 
relational database in order to detect loads and balance loads among the various components or 
20 make other adjustments as necessary to ensure efficient operation of the reporting system 1 00. 
Additionally, the intelligence server 300 may include an administrative module (not shown) that 
fulfills administrative requests for information about current usage activity on the intelligence 
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server 300 and executes administrative commands to change operating settings and governors. A 
command manager tool (not shown) may also be utilized to facilitate the performance of certain 
administrator tasks. These command manager capabilities allow additions, deletions, or updates 
to enterprise-level data associated with large numbers of users and user groups. The command 
5 manager tool may include a command manager graphical user interface (GUI), a command 
manager executor (a tools asynchronous processing function set), and capabilities available 
through a command line. The command line may be a console whereby a user may input text 
O commands directly to a server. Such text commands provide the ability to perform various 
j Jf administrative tasks easily and effectively. For example, administrative tasks that are repetitive, 
J) such as creating a user on the reporting system 1 00, or, alternatively, tasks that are performed in 
i|| bulk may be performed more easily through utilization of the command line than through 
1 3 utilization of conventional techniques. In order to utilize this feature, a text script may be 
created and stored in a text file. The text file may be changed utilizing copying and pasting 
j*f techniques within that text file, for example. This text file may then be saved and utilized in bulk 
1 5 operations. Thereafter, the entire text file may be submitted to a command line processor all at 
once. As a result, certain tasks may be easily performed in bulk. It should be appreciated that a 
typical user of the reporting system 100 will commonly interface with the reporting system 100 
in a manner which is very interactive. In contrast, an administrative user who is supporting the 
reporting system 100 often desires to conduct tasks in bulk and as quickly as possible. Thus, an 
20 administrative user may create a substantial number of users, change a substantial number of 
users' passwords, or adjust a wide variety of administrative settings by utilizing this tool, for 
example. 
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This intelligent portal architecture minimizes the client/server communication by keeping 
an object server, report server, and administrative server at the client (user) side to cache all prior 
user-requested objects. In this architecture, most calls to a cached object will be handled within 
the user engine 102 to achieve the best performance. For example, during the editing of an 
object, e.g., a filter, all operation on the filter is handled on the client (user engine 102) side. 
When the editing is completed, the entire definition of the filter will be transported to the 
intelligence server side 300 of the reporting system 100. 

Another advantage of the plug-in component nature of the intelligence server 300 is that 
any part of the server functions may be moved outside the intelligence server 300 into a 
secondary server. For example, if running a report requires too much of the reporting system 100 
resources, the SQL engine 302, the query engine 106, and/or the analytical engine 104 may be 
moved outside of the intelligence server 300 into a secondary server which has a main 
responsibility to run a report. The architecture may also be configured to have one main 
intelligence server 300 and multiple secondary servers. As another alternative, the reporting 
system 100 may also be configured so that there are a plurality of user engines 102, a plurality of 
intelligence servers 300 and a plurality of data storage devices 108. In such a system, each of the 
plurality of intelligence servers 300 may include an analytical engine 104 and a query engine 106, 
in addition to the other component modules. 

In addition to the various components of the intelligence server 300 illustrated in Fig. 3, 
components may be provided in the application logic layer for one or more of object browsing, 
report viewing, server monitoring, and object construction and administration. Each of these 
components also will interact with associated APIs. 
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It should be noted that the functions associated with the intelligence server system may be 
implemented in hardware or software. For example, specific electronic components may be 
employed in a user engine 102 and an intelligence server 300 for implementing the functions 
associated with the intelligence server system. Alternatively, one or more processors operating in 
5 accordance with stored instructions may implement the functions associated with the intelligence 
server system 300. If such is the case, it is within the scope of the present invention that such 
instructions may be transmitted to the user engine 102 and the intelligence server 300 via one or 

2 more signals. 

The intelligent portal architecture of the intelligence server 300, utilizing plug-in 
ft) components which may be invoked on an as-needed basis enable the implementation of a robust 
|| reporting system 1 00 which may be easily integrated into web-based user applications and 

3 facilitates customization of reports. Moreover, the resulting system 100 is scalable to millions of 
:f potential users and terabytes of data, 

I It will be apparent to those skilled in the art that various modifications and variations can 

1 5 be made in the apparatuses and methods of the present invention without departing from the 
scope or spirit of the invention. Thus, it is intended that the present invention cover the 
modifications and variations of this invention provided they come within the scope of the 
appended claims and their equivalents. 
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